草庐IT

Java JUnit assertEquals 与 Long

全部标签

c++ - long int* 到 np_intp* 平台相关转换

在我的64位办公桌面上,编译正常:#include#include...Py_Initialize();import_array();//BuildarrayobjectlongintNUMEL=3;PyObject*out_array=PyArray_SimpleNew(1,&NUMEL,NPY_DOUBLE);相反,在我的32位笔记本电脑上,这无法产生错误:error:invalidconversionfrom‘longint*’to‘npy_intp*{akaint*}’[-fpermissive]PyArray_New(&PyArray_Type,nd,dims,typenum

c++ - "Int"c++ 与 "long long"结果的乘法

这个问题在这里已经有了答案:Squaringnumberinc++,Kaprekarnumbers[duplicate](3个答案)关闭6年前。我正在尝试计算int的平方。我的代码如下所示:longlongsqr=0;intnum=77778;sqr=num*num;结果应该是6049417284但是当我检查输出时,它显示1754449988。我在做什么错误?longlong应该能够存储结果,但为什么我得到了不同的值?

c++ - 将 long 转换为 wchar_t *

感谢阅读。我认为我在这方面已经很接近了,但我可以利用一些专业知识来理解为什么我对某事的尝试没有按照我期望的方式进行。我(目前)需要的是将long类型(LONG,因为我实际上是在VC++中,但我知道这只是一个typedef)转换为wchar_t*。我能够获得我想要的结果,但我无法理解为什么我认为应该起作用的方法……不起作用。这是实现我想要的结果的代码:conststd::wstringmyString{std::to_wstring(wRect.bottom)};constwchar_t*myCharPointer{myString.c_str()};与我想采用的方法相比:constwc

将 double 添加到 long long 时出现 C++ 精度错误

这个问题在这里已经有了答案:ImplicittypeconversionrulesinC++operators(9个回答)关闭4年前。我注意到,在将double添加到longlong时,VisualStudio会出现精度错误。例如:longlonga=44981600439878676;doubleb=234567890;a+=b;a的结果是44981600674446560,但应该是44981600674446566。它发生在x32和x64上。但是以下返回正确的值:longlonga=44981600439878676;doubleb=234567890;a+=(longlong)b

c++ - 为什么 `uint64_t` 的模板特化与 Mac 平台上的 `unsigned long` 不匹配?

这个问题在这里已经有了答案:longlongintvs.longintvs.int64_tinC++(3个答案)关闭3年前。为什么以下代码片段在Mac平台上使用clang++编译失败?sizeofunsignedlong和uint64_t都是8,所以我认为它们是同一类型。那么为什么编译认为Serializer是抽象的吗?因为我定义了Serializer,Serializer,Serializer,Serializer,Serializer,Serializer,Serializer,Serializer,有没有办法解决这个问题并避免定义更多类型,如Serializer?错误信息如下,c

c++ - 从二进制文件读取字节到 long int

我有两个问题:我有一个二进制文件中的数据。我想通过使用读取函数读取前8个字节以签名longint,但我不能。你知道我该怎么做吗?如何直接读取一段数据为字符串?我可以像中所示那样阅读吗例如:ifstreamis;is.open("test.txt",ios::binary);stringstr;is.read(str.c_str,40);//40bytesshouldberead 最佳答案 Iwantreadfirst8bytestosignedlongintbyusingreadfunctionbutIcouldnot.Doyouk

c++ - 转换 int -> unsigned long long 是否由标准定义

我无法在标准中找到关于如何将int值转换为unsignedlonglong的确切规范。指定了各种类似的转换,如int->unsigned、unsigned->int(UBifnegative)、unsignedlonglong->int等例如GCC,-1被转换为0xffffffffffffffff,而不是0x00000000ffffffff。我可以依赖这种行为吗? 最佳答案 是的,这个定义很明确,它基本上是将maxunsignedlonglong+1添加到-1,它始终是maxunsignedlonglong。这包含在draftC++

c# - 正确地将 C++ long 转换为 C# int

我目前正在使用以非托管C++编写的业务逻辑库开发.NETFramework4.7.2应用程序。我需要使用非托管C++。我需要使用C++项目中的逻辑,不幸的是我无法正确转换程序的输入或输出参数。当我输入42并只想返回该值时,结果是17582022。这实际上应该是42。我的C++代码如下所示:MYCore头文件:#ifdefMYCORE_EXPORTS#defineMYCORE_API__declspec(dllexport)#endif#pragmaonce#includeusingnamespacestd;extern"C"{classMYCORE_APITestClass{priva

c++ - 为什么这个 EXC_BAD_ACCESS 发生在 long long 而不是 int 上?

我遇到了一个EXC_BAD_ACCESS,其中包含一段处理数据序列化的代码。该代码仅在设备(iPhone)上失败,在模拟器上不会。它还仅在某些数据类型上失败。这是重现问题的测试代码:templatevoidtest_alignment(){//allocatememoryandrecordtheoriginaladdressunsignedchar*origin;unsignedchar*tmp=(unsignedchar*)malloc(sizeof(unsignedshort)+sizeof(T));origin=tmp;//pushdatawithsizeof2bytes*((u

c++ - 从 unsigned long long 转换为 float with round 到最接近的偶数

我需要编写一个函数,将unsignedlonglong舍入为float,并且舍入应朝向最近的偶数。我不能只进行C++类型转换,因为AFAIK标准没有指定舍入。我正在考虑使用boost::numeric,但在阅读文档后我找不到任何有用的线索。这可以使用那个库来完成吗?当然,如果有替代方案,我会很乐意使用它。如有任何帮助,我们将不胜感激。编辑:添加示例以使事情更清楚一些。假设我想将0xffffff7fffffffff转换为其浮点表示形式。C++标准允许以下任一项:0x5f7fffff~1.9999999*2^630x5f800000=2^64现在,如果你加上最接近偶数的舍入限制,只有第一个